rev1(nil) -> nil
rev1(rev1(x)) -> x
rev1(++2(x, y)) -> ++2(rev1(y), rev1(x))
++2(nil, y) -> y
++2(x, nil) -> x
++2(.2(x, y), z) -> .2(x, ++2(y, z))
++2(x, ++2(y, z)) -> ++2(++2(x, y), z)
make1(x) -> .2(x, nil)
↳ QTRS
↳ DependencyPairsProof
rev1(nil) -> nil
rev1(rev1(x)) -> x
rev1(++2(x, y)) -> ++2(rev1(y), rev1(x))
++2(nil, y) -> y
++2(x, nil) -> x
++2(.2(x, y), z) -> .2(x, ++2(y, z))
++2(x, ++2(y, z)) -> ++2(++2(x, y), z)
make1(x) -> .2(x, nil)
REV1(++2(x, y)) -> REV1(x)
REV1(++2(x, y)) -> REV1(y)
++12(x, ++2(y, z)) -> ++12(++2(x, y), z)
REV1(++2(x, y)) -> ++12(rev1(y), rev1(x))
++12(x, ++2(y, z)) -> ++12(x, y)
++12(.2(x, y), z) -> ++12(y, z)
rev1(nil) -> nil
rev1(rev1(x)) -> x
rev1(++2(x, y)) -> ++2(rev1(y), rev1(x))
++2(nil, y) -> y
++2(x, nil) -> x
++2(.2(x, y), z) -> .2(x, ++2(y, z))
++2(x, ++2(y, z)) -> ++2(++2(x, y), z)
make1(x) -> .2(x, nil)
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
REV1(++2(x, y)) -> REV1(x)
REV1(++2(x, y)) -> REV1(y)
++12(x, ++2(y, z)) -> ++12(++2(x, y), z)
REV1(++2(x, y)) -> ++12(rev1(y), rev1(x))
++12(x, ++2(y, z)) -> ++12(x, y)
++12(.2(x, y), z) -> ++12(y, z)
rev1(nil) -> nil
rev1(rev1(x)) -> x
rev1(++2(x, y)) -> ++2(rev1(y), rev1(x))
++2(nil, y) -> y
++2(x, nil) -> x
++2(.2(x, y), z) -> .2(x, ++2(y, z))
++2(x, ++2(y, z)) -> ++2(++2(x, y), z)
make1(x) -> .2(x, nil)
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
++12(x, ++2(y, z)) -> ++12(++2(x, y), z)
++12(x, ++2(y, z)) -> ++12(x, y)
++12(.2(x, y), z) -> ++12(y, z)
rev1(nil) -> nil
rev1(rev1(x)) -> x
rev1(++2(x, y)) -> ++2(rev1(y), rev1(x))
++2(nil, y) -> y
++2(x, nil) -> x
++2(.2(x, y), z) -> .2(x, ++2(y, z))
++2(x, ++2(y, z)) -> ++2(++2(x, y), z)
make1(x) -> .2(x, nil)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
++12(.2(x, y), z) -> ++12(y, z)
Used ordering: Polynomial interpretation [21]:
++12(x, ++2(y, z)) -> ++12(++2(x, y), z)
++12(x, ++2(y, z)) -> ++12(x, y)
POL(++2(x1, x2)) = x1 + x1·x2 + x2
POL(++12(x1, x2)) = 3·x1 + 3·x1·x2 + 3·x2
POL(.2(x1, x2)) = 3 + 2·x1 + x1·x2 + 3·x2
POL(nil) = 3
++2(.2(x, y), z) -> .2(x, ++2(y, z))
++2(nil, y) -> y
++2(x, ++2(y, z)) -> ++2(++2(x, y), z)
++2(x, nil) -> x
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDPOrderProof
↳ QDP
++12(x, ++2(y, z)) -> ++12(++2(x, y), z)
++12(x, ++2(y, z)) -> ++12(x, y)
rev1(nil) -> nil
rev1(rev1(x)) -> x
rev1(++2(x, y)) -> ++2(rev1(y), rev1(x))
++2(nil, y) -> y
++2(x, nil) -> x
++2(.2(x, y), z) -> .2(x, ++2(y, z))
++2(x, ++2(y, z)) -> ++2(++2(x, y), z)
make1(x) -> .2(x, nil)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
++12(x, ++2(y, z)) -> ++12(++2(x, y), z)
++12(x, ++2(y, z)) -> ++12(x, y)
POL(++2(x1, x2)) = 3 + 2·x1 + x1·x2 + 3·x2
POL(++12(x1, x2)) = 2·x1 + x1·x2 + 3·x2
POL(.2(x1, x2)) = x1 + x2
POL(nil) = 2
++2(.2(x, y), z) -> .2(x, ++2(y, z))
++2(nil, y) -> y
++2(x, ++2(y, z)) -> ++2(++2(x, y), z)
++2(x, nil) -> x
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
rev1(nil) -> nil
rev1(rev1(x)) -> x
rev1(++2(x, y)) -> ++2(rev1(y), rev1(x))
++2(nil, y) -> y
++2(x, nil) -> x
++2(.2(x, y), z) -> .2(x, ++2(y, z))
++2(x, ++2(y, z)) -> ++2(++2(x, y), z)
make1(x) -> .2(x, nil)
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
REV1(++2(x, y)) -> REV1(y)
REV1(++2(x, y)) -> REV1(x)
rev1(nil) -> nil
rev1(rev1(x)) -> x
rev1(++2(x, y)) -> ++2(rev1(y), rev1(x))
++2(nil, y) -> y
++2(x, nil) -> x
++2(.2(x, y), z) -> .2(x, ++2(y, z))
++2(x, ++2(y, z)) -> ++2(++2(x, y), z)
make1(x) -> .2(x, nil)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
REV1(++2(x, y)) -> REV1(y)
REV1(++2(x, y)) -> REV1(x)
POL(++2(x1, x2)) = 3 + 2·x1 + x2
POL(REV1(x1)) = x1 + 3·x12
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
rev1(nil) -> nil
rev1(rev1(x)) -> x
rev1(++2(x, y)) -> ++2(rev1(y), rev1(x))
++2(nil, y) -> y
++2(x, nil) -> x
++2(.2(x, y), z) -> .2(x, ++2(y, z))
++2(x, ++2(y, z)) -> ++2(++2(x, y), z)
make1(x) -> .2(x, nil)